草庐IT

c++ - 将 JSON 插入 Mongocxx

全部标签

ruby - 使用 ruby​​-yajl 解析大型 JSON 哈希?

我有一个包含JSON散列的大文件(>50Mb)。像这样的东西:{"obj1":{"key1":"val1","key2":"val2"},"obj2":{"key1":"val1","key2":"val2"}...}与其解析整个文件并取前十个元素,不如解析散列中的每个项目。我实际上并不关心key,即obj1。如果我将上面的转换为:{"key1":"val1","key2":"val2"}"obj2":{"key1":"val1","key2":"val2"}我可以使用Yajl流轻松实现我想要的:io=File.open(path_to_file)count=10Yajl::Parse

ruby-on-rails - 使用机架中间件捕获无效的 JSON 解析错误

我正在使用Rails5,我正在尝试改进对我的API的无效JSON请求的错误处理。我尝试通过救援在Controller中解析来处理无效格式的JSON,但意识到如果用户将ContentType添加到他们的请求header,Rails中间件会在我的JSON请求到达Controller之前解析它。我遵循了以下指南:https://robots.thoughtbot.com/catching-json-parse-errors-with-custom-middleware但是,在启动服务器时出现以下错误:.rbenv/versions/2.3.1/lib/ruby/gems/2.3.0/gems

ruby - 如何在 ruby​​ 中设置 header ['content-type' ] ='application/json'

require'net/http'require'rubygems'require'json'url=URI.parse('http://www.xyxx/abc/pqr')resp=Net::HTTP.get_response(url)#get_responsetakesanURIobjectdata=resp.bodyputsdata这是我在ruby​​中的代码,resp.data以xml形式提供给我数据。restapi默认返回xml数据,如果headercontent-type是application/json,则返回json。但我想要json格式的数据。为此我必须设置heade

ruby - 如何在 Ruby 数组的所有元素之间插入一个新元素?

我有一个数组,想在所有元素之间插入一个新元素,类似于join方法。例如,我有[1,[],"333"]我需要的是[1,{},[],{},"333"]请注意,在所有元素之间插入了一个新的空散列。编辑:目前我拥有的是:irb(main):028:0>a=[1,[],"333"]=>[1,[],"333"]irb(main):029:0>a=a.inject([]){|x,y|x[1,{},[],{},"333",{}]irb(main):030:0>a.pop=>{}irb(main):031:0>a=>[1,{},[],{},"333"]irb(main):032:0>我想知道最好的方法。

ruby - 将 OpenStruct 深度转换为 JSON

我有一个OpenStruct,它嵌套在许多其他OpenStructs中。将它们全部深度转换为JSON的最佳方法是什么?理想情况下:x=OpenStruct.newx.y=OpenStruct.newx.y.z=OpenStruct.newz='hello'x.to_json//{y:z:'hello'}现实{} 最佳答案 没有默认方法来完成这样的任务,因为内置的#to_hash返回哈希表示,但它不会深度转换值。如果值是OpenStruct,它会原样返回,不会转换成Hash。然而,这并不难解决。您可以创建一个遍历OpenStruct实

ruby - 如何让 Ruby JSON 解析器忽略 json_class?

我有一个序列化的JSON字符串(实际上是chef角色定义),它有一个json_class键,使ruby​​JSON解析器试图强制它成为一个Chef::Role对象。我怎样才能让解析器忽略这个键,只是简单地反序列化成一个普通的哈希? 最佳答案 我遇到了同样的问题,通过阅读JSONgem的源代码找到了答案——在尝试解析之前取消设置JSON.create_id:JSON.create_id=nilJSON.parse('{"json_class":"Chef::Role"}').class=>Hash编辑:请注意,由于gem的版本为1.7

ruby-pg 在插入之前清理数据

这里是Ruby新手。我正在尝试插入此字符串“LadyArabella'sScandalo...”我正在使用ruby​​-pg来执行此操作。但是由于单引号我有错误,我怎样才能清理这个字符串并删除所有html标签?是否有内置函数? 最佳答案 您可以使用escape_string正确转义你的单引号:db=PG.connect(...)db.exec("insertintot(...)values('#{db.escape_string(str)}',...)")或使用prepare和exec_prepared改为使用准备好的语句:db.p

ruby-on-rails - 在 Rails 中使用数组解析 JSON

我有远程服务器返回的以下JSON字符串:{"users":[{"user_id":1,"name":"ChrisRivers",},{"user_id":3,"name":"PeterCurley",}]}我想迭代用户。ActiveSupport::JSON.decode(response.body)["users"].eachdo|user|putsuser["name"]end据我所知,问题是:ruby无法将ActiveSupport::JSON.decode(response.body)["users"]识别为数组,因此puts只返回第一个用户。我该如何解决这个问题?

Ruby:如何将数据数组转换为哈希和 json 格式?

我对Ruby数组和散列操作还很陌生。我怎样才能完成这个简单的转换?array=[#,#,#]json格式的期望输出:[{id:1,car:'red'},{id:2,car:'yellow'},{id:3,car:"green"}]有没有人有任何提示? 最佳答案 array.map{|o|Hash[o.each_pair.to_a]}.to_json 关于Ruby:如何将数据数组转换为哈希和json格式?,我们在StackOverflow上找到一个类似的问题:

ruby - 如何在 Ruby 中插入或更新之前转义字符串

在ruby​​中,ActiveRecord不提供更新和插入sql的动态绑定(bind),当然我可以使用原始sql,但是需要保持连接,所以我想知道是否有更简单的方法在执行之前转义更新或插入sql像下面的代码:ActiveRecord::Base.connection.insert(sql)我想我可以用gsub写代码,但我知道是否有现成的方法来做。 最佳答案 在Rails>=3.2.5中,以下对我有用:evil_input='"\';%#{}\"foo'ActiveRecord::Base.connection.quote(evil_i